<template>
  <el-dropdown trigger="click">
    <el-button icon="Setting" size="default">列设置</el-button>
    <template #dropdown>
      <el-dropdown-menu>
        <el-dropdown-item>
          <span class="title">列设置</span>
          <Draggable class="t_table_column_setting_dropdown" v-model="state.columnSet" item-key="prop">
            <template #item="{element,index}">
              <el-checkbox :checked="!element.hidden" @click.native.stop :disabled="element.disabled"
                @change="checkChanged(checked, index)">
                {{element.label}}
              </el-checkbox>
            </template>
          </Draggable>
        </el-dropdown-item>
      </el-dropdown-menu>
    </template>
  </el-dropdown>
</template>
<script lang="ts">
export default {
  name: 'ColumnSelect'
}
</script>
<script setup lang="ts">
import Draggable from 'vuedraggable'
import { watch, onMounted, reactive } from 'vue'
const props = defineProps({
  columns: {
    type: Array,
    default: () => []
  },
  title: {
    type: String,
    default: ''
  },
  name: {
    type: String,
    default: ''
  }
})
// 初始化
const initColumnSet = () => {
  const columnSet = props.columns.map((col: any) => ({
    label: col.label,
    prop: col.prop,
    hidden: false,
    disabled: false
  }))
  return columnSet
}
// 获取缓存数据
const getColumnSetCache = () => {
  const value = localStorage.getItem(`t-ui-plus:TTable.columnSet-${props.name || props.title}`)
  if (value) {
    let columns = JSON.parse(value);
    columns
  } else {
    return initColumnSet();
  }
  return value ? JSON.parse(value) : initColumnSet()
}
// 抛出事件
const emits = defineEmits(['columnSetting'])
const state: any = reactive({
  columnSet: []
})
onMounted(() => {
  state.columnSet = getColumnSetCache()
  // console.log('onMounted', state.columnSet)
  emits('columnSetting', state.columnSet)
})
watch(
  () => state.columnSet,
  (val) => {
    emits('columnSetting', val)
    // console.log(3333, val)
    localStorage.setItem(`t-ui-plus:TTable.columnSet-${props.name || props.title}`, JSON.stringify(val))
  },
  { deep: true }
)
// checkbox改变选中状态
const checkChanged = (checked:boolean, index:number) => {
  state.columnSet[index].hidden = !checked
  let obj: any = {}
  state.columnSet.map(val => {
    val.hidden in obj || (obj[val.hidden] = [])
    obj[val.hidden].push(val.hidden)
  })
  if (obj.length < 2) {
    state.columnSet.map((val, key) => {
      if (!val.hidden) {
        state.columnSet[key].disabled = true
      }
    })
  } else {
    state.columnSet.map((val, key) => {
      if (!val.hidden) {
        state.columnSet[key].disabled = false
      }
    })
  }
}

</script>
<style lang="scss">
.el-dropdown-menu {
  padding: 10px;
  font-size: 14px;
  .el-dropdown-menu__item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    .title {
      font-weight: bold;
      margin-bottom: 5px;
    }
    .t_table_column_setting_dropdown {
      display: flex;
      flex-direction: column;
      max-height: 300px;
      overflow-y: auto;
      .el-checkbox {
        .el-checkbox__input.is-checked+.el-checkbox__label {
          color: #262626;
        }
      }
    }
  }
}
</style>
